草庐IT

php - 通过php迁移数据库

全部标签

ruby - 如何以较低的速度运行 Selenium(通过 Capybara 使用)?

默认情况下,Selenium在我使用Cucumber定义的场景中尽可能快地运行。我想将它设置为以较低的速度运行,这样我就可以拍摄该过程的视频。我发现Selenium::Client::Driver的一个实例有一个set_speed方法。对应于JavaAPI.如何获取Selenium::Client::Driver类的实例?我可以得到page.driver,但它返回Capybara::Driver::Selenium的实例。 最佳答案 感谢http://groups.google.com/group/ruby-capybara/msg

ruby-on-rails - 在 Ruby 中,如何从 CSV 文件中按列读取数据?

我知道它是如何逐行完成的CSV.foreach(filename.csv)do|row|puts"#{row}"end但我完全迷失了专栏? 最佳答案 测试.csv:name,surname,no1,no2,no3,dateRaja,Palit,77489,24,84,12/12/2011Mathew,bargur,77559,25,88,01/12/2011harin,Roy,77787,24,80,12/12/2012Soumi,paul,77251,24,88,11/11/2012按列访问:require'csv'csv=CSV

ruby-on-rails - 从 Rails 控制台修改数据库 ID?

我有一个小型数据库,一直在通过Rails页面添加条目。我“销毁”了其中一个条目,现在我的ID序列跳过了一个。例如,我现在有42然后是44,而不是显而易见的:42、43、44。我想知道是否有办法通过控制台编辑新对象的ID号。我试过:record.id=43record.save和record=record.newrecord.attributes={:id=>43}但两者均无效。我相当确定必须有一个控制台方法,但我似乎无法在谷歌上找到更多具体信息,而且我可能错误地阅读了RailsAPI......我是否可能必须通过sqlite中的直接SQL来执行此操作?谢谢

ruby - 使用 Ruby 和 Minitest,如何运行具有不同数据的相同测试用例,仅由列表控制

我有对电话号码进行操作的Ruby2.0代码,我想使用MiniTest对其进行测试。我有一个函数,它接受一个电话号码参数并对其进行测试(包括断言)。每次调用该函数时,我都希望它成为一个新的测试用例。像这样:listOfPhoneNumbersForTesting.each{|phone|testphonephone}我不想要的是:classtest2125551212...重复10、20或100次以测试每个电话号码...显然,我可以将循环代码放在MiniTest::Unit::TestCase中,但无论我测试多少个电话号码,这都会导致只有一个测试用例,我不喜欢这样。(此外,如果其中一个断

ruby-on-rails - 将索引添加到数据模型 - Ruby on Rails 教程

我对在RubyonRailsTutorial.org中找到的这段代码有点困惑。它的add_index部分究竟做了什么?为什么这里有3行?classCreateRelationships 最佳答案 Adatabaseindexisadatastructurethatimprovesthespeedofoperationsinatable.Indexescanbecreatedusingoneormorecolumns,providingthebasisforbothrapidrandomlookupsandefficientorder

ruby - 如何将 Ruby 脚本的输出通过管道传输到 'head' 而不会出现管道损坏错误

我有一个简单的Ruby脚本,看起来像这样require'csv'whileline=STDIN.getsarray=CSV.parse_line(line)putsarray[2]end但是当我尝试在这样的Unix管道中使用此脚本时,我得到10行输出,然后是一个错误:rubylib/myscript.rb(Errno::EPIPE)有没有一种方法可以以防止引发破损管道异常的方式编写Ruby脚本? 最佳答案 head在读取所有需要的数据后关闭标准输出流。您应该处理异常并停止写入标准输出。一旦标准输出关闭,以下代码将中止循环:while

ruby-on-rails - 通过 ruby​​ 代码读取和更新 YAML 文件

我写了一个这样的yml文件:last_update:'2014-01-2811:00:00'我正在阅读这个文件config=YAML.load('config/data.yml')稍后我访问last_update_time作为config['last_update']但它不工作。另外我想通过我的ruby​​代码更新last_update_time就像它应该更新一样:last_update:'2014-01-2923:59:59'我不知道该怎么做。 最佳答案 将.load切换为.load_file,您应该可以开始了。#!/usr/bi

ruby-on-rails - 如何配置额外的/不同的迁移文件夹

我和一位同事在共享某些模型的不同项目中工作。因此,我们通过git子模块共享模型。此外,我们还希望能够共享迁移:这样,我同事的迁移将在我项目的文件夹db/migrate/other_db中。如何配置Rails迁移以在这个额外的文件夹中运行迁移? 最佳答案 在您的配置文件中(config/application.rb用于所有环境或config/environments/$(environment).rb仅用于特定环境)添加此行:config.paths['db/migrate']+='db/migrate/other_db'如果你想改变

Ruby 通过索引访问多个数组元素(子数组)

我有一个数组,还有一个数组,其中包含第一个数组中某些元素的索引。从第一个数组中获取元素的最佳方法是什么?我在做:result=[]indexes.each{|current|result但应该有更好的方法.. 最佳答案 您可以使用Array#map:indexes.map{|i|my_array[i]}或者更好,Array#values_atmy_array.values_at(*indexes)*符号将数组提取到传递给方法的参数中。 关于Ruby通过索引访问多个数组元素(子数组),我们

ruby-on-rails - 如何在不初始化 Rails 的情况下从 schema.rb 创建数据库?

我正在尝试从schema.rb创建我所有的表我使用了命令:“rakedb:schema:load”但是,这失败了,因为在我的一个初始化器中,它引用了一个显然不存在的模型/表(因为数据库是空的)我可以注释掉这些行,然后再次运行schema:load,但是有其他选择吗? 最佳答案 可能最快的方法是将有问题的初始化程序移动到应用程序外部的临时目录,然后运行您的模式加载。但是,如果这不起作用,或者由于某种原因不是一个选项,您总是可以通过创建一个简单的rails应用程序来执行模式加载来解决这个问题:创建一个新的Rails应用:railsnew